<template>
  <div class="reportFormPage horizontal-border" v-if="show">
    <div class="report-dom horizontal">
      <el-row>
        <el-col :span="5" :offset="19">
          <div class="pageNumBox">
            <span>第</span>
            <span class="placeholder-min text-center">&nbsp;{{ form.page }}&nbsp;</span>
            <span>页，共</span>
            <span class="placeholder-min text-center">&nbsp;{{ form.totalPage }}&nbsp;</span>
            <span>页</span>
          </div>
        </el-col>
      </el-row>
      <div class="topTwoBox">
        <div class="centerName">{{ this.form.baobmc }}</div>
        <div class="codeText">
          <tr v-for="(item, index) in form.baobbhList">{{ item }}</tr>
        </div>
      </div>
      <div class="threeTopBox">
        <div class="left-border">
          <div class="box-title">检测单位名称：</div>
          <div class>{{ form.jiancdwmc }}</div>
        </div>
        <div class="right-border">
          <span>记录编号：</span>
          <span class="placeholder">{{ form.jilbh }}</span>
        </div>
      </div>
      <!-- .........................1111111111111111111111111111111......................................................... -->
      <div class="table-border">
        <table height="160px" class="top-table">
          <tbody>
          <tr>
            <td height="30" align="center" width="15%">
              <span style="width: 90px; display: inline-block">工程名称</span>
            </td>
            <td width="35%" class="text-center">
              <span>{{ form.gongcmc }}</span>
            </td>
            <td align="center" width="15%">
              <span style="width: 90px; display: inline-block">工程部位/用途</span>
            </td>
            <td width="35%" class="text-center">
              <span>{{ form.gongcbwyt }}</span>
            </td>
          </tr>
          <tr>
            <td height="30" align="center">样品信息</td>
            <td class="specimen-border" colspan="3">
              <span>样品名称：</span>
              <span :class="{ 'placeholder': !form.yangpmc }">{{ form.yangpmc }}</span>
              <span>；样品编号：</span>
              <span :class="{ 'placeholder-long': !form.yangpbh }">{{ form.yangpbh }}</span>

              <span>；样品数量：</span>
              <span :class="{ 'placeholder': !form.yangpsl }">{{ form.yangpsl }}</span>
              <span>；样品状态：</span>
              <span :class="{ 'placeholder': !form.yangpzt }">{{ form.yangpzt }}</span>
              <span>；来样时间：</span>
              <span :class="{ 'placeholder': !form.yangpsj }">{{ form.yangpsj }}</span>
            </td>
          </tr>
          <tr>
            <td height="25" align="center" width="15%">
              <span style="width:90px;display:inline-block">试验检测日期</span>
            </td>
             <!-- <td width="35%" class="text-center">{{ form.shiyjcrq }}</td> -->                                            
 <td width="35%" class="text-center">
      <el-input v-model="form.shiyjcrq" />
</td>
            <td align="center" width="15%">
              <span style="width:90px;display:inline-block">试验条件</span>
            </td>
            <td v-if="isPdf" width="35%">
              温度：
              <span style="display: inline-block; width: 10%;">{{ form.shiytjwd }}</span>
              ℃；湿度：
              <span style="display: inline-block; width: 10%;">{{ form.shiytjsd }}</span>%RH
            </td>
            <td v-else width="35%">
              温度：
              <el-input :type="isPdf ? 'string' : 'number'" v-model="form.shiytjwd" class="height100"
                        style="width: 15%" @blur="setHntqdhtfBgShiytj()" />℃；湿度：
              <el-input :type="isPdf ? 'string' : 'number'" v-model="form.shiytjsd" class="height100"
                        style="width: 15%" @blur="setHntqdhtfBgShiytj()" />%RH
            </td>
          </tr>
          <tr>
            <td height="40" align="center" width="15%">
              <span style="width: 90px; display: inline-block">检测依据</span>
            </td>
            <td width="35%">
              <span v-if="isPdf">{{ form.jiancyj }}</span>
              <el-input v-else type="textarea" v-model="form.jiancyj" :rows="2" class="mark"
                        @dblclick.native="showBsJiancyjView" readonly />
            </td>
            <td align="center" width="15%">
              <span style="width: 90px; display: inline-block">判定依据</span>
            </td>
            <td width="35%">
              <span v-if="isPdf">{{ form.pandyj }}</span>
              <el-input v-else type="textarea" v-model="form.pandyj" :rows="2" @dblclick.native="showBsJudgeBaseView"
                        @focus="handleFocus('pandyj')" class="mark" />
            </td>
          </tr>
          <tr class="bottom-border">
            <td height="30" align="center">
              <div>主要仪器设备</div>
              <div>名称及编号</div>
            </td>
            <td colspan="3">
              <span v-if="isPdf">{{ form.zhuyyqsbmcjbh }}</span>
              <el-input v-else type="textarea" :rows="2" v-model="form.zhuyyqsbmcjbh" class="height100 width100 mark"
                        @dblclick.native="showBsInstrumentView" readonly></el-input>
            </td>
          </tr>
          </tbody>
        </table>
        <!-- .................................22222222222222222222222222222222............................................... -->
        <table height="360px" class="middle-table">
          <tbody>
          <tr>
            <td>取样地点</td>
            <td>
              <el-input tabindex="200" v-model="form.quydd" />
            </td>
            <td>乳化沥青品种</td>
            <td>
              <el-input tabindex="200" v-model="form.ruhlqpz" />
            </td>
            <td>乳化沥青代号</td>
            <td>
              <el-input tabindex="200" v-model="form.ruhlqdh" />
            </td>
          </tr>
          <tr>
            <td>基质沥青产地</td>
            <td>
              <el-input tabindex="200" v-model="form.ruhlqcd" />
            </td>
            <td>基质沥青种类</td>
            <td>
              <el-input tabindex="200" v-model="form.ruhlqzl" />
            </td>
            <td>基质沥青标号</td>
            <td>
              <el-input tabindex="200" v-model="form.ruhlqbh" />
            </td>
          </tr>
          <tr>
            <td>样品编号</td>
            <td>试样容器、玻璃棒合计质量（g)</td>
            <td>试样容器、玻璃棒及乳液合计质量（g)</td>
            <td>试样容器、玻璃棒及残留物合计质量（g)</td>
            <td>蒸发残留物含量（%）</td>
            <td>蒸发残留物含量平均值（%）</td>
          </tr>
          <tr v-for="(item, index) in form.detailList">
            <td v-if="index%2==0" rowspan="2">
              <el-input tabindex="200" v-model="item.yangpbh" />
            </td>
            <td>
              <el-input :type="isPdf ? 'string' : 'number'" tabindex="200" v-model="item.hejzl" @blur="calcClw(index)" />
            </td>
            <td>
              <el-input :type="isPdf ? 'string' : 'number'" tabindex="200" v-model="item.ruyhjzl" @blur="calcClw(index)" />
            </td>
            <td>
              <el-input :type="isPdf ? 'string' : 'number'" tabindex="200" v-model="item.canlwhjzl" @blur="calcClw(index)" />
            </td>
            <td>
              {{item.canlwhl}}
            </td>
            <td v-if="index%2==0" rowspan="2">
              {{item.canlwhlPjz}}
            </td>
          </tr>
          </tbody>
        </table>
        <!-- .....................................................33333333333333333................................................... -->
        <table height="30px" class="bottom-table">
          <tr>
            <td>
              <span v-if="isPdf" class="textarea-span">{{ form.fujsm }}</span>
              <el-input v-else type="textarea" :rows="2" v-model="form.fujsm" @focus="handleFocus('fujsm')" />
            </td>
          </tr>
        </table>
      </div>
      <!-- .................................44444444444............................................. -->
      <table height="22px" class="transparent">
        <tbody>
        <tr>
          <td width="10%" align="right">检测：</td>
          <td width="15%" align="left">
            <!-- {{this.form.jiancr}} -->
          </td>
          <td width="10%" align="right">记录：</td>
          <td width="15%" align="left">
            <!-- {{this.form.jilr}} -->
          </td>
          <td width="10%" align="right">复核：</td>
          <td align="left" width="15%">
            <!-- {{this.form.fuhr}} -->
          </td>
          <td width="10%">日期：</td>
          <td align="left" width="15%">
            <div style="display: inline-block; margin-right: 30px;">年</div>
            <div style="display: inline-block; margin-right: 30px;">月</div>
            <div style="display: inline-block;">日</div>
          </td>
        </tr>
        </tbody>
      </table>
    </div>
    <bs-instrument-view ref="bsInstrumentViewRef" @select="selectInstrument"></bs-instrument-view>
    <bs-jiancyj-view ref="bsJiancyjViewRef" @select="selectJiancyj" :syType="syType"></bs-jiancyj-view>
    <bs-judge-base-view ref="bsJudgeBaseViewRef" @select="selectJudge" :syType="syType"></bs-judge-base-view>
  </div>
</template>

<script>
  import decimal from "@/utils/big-decimal";
  import Bus from "@/utils/bus";
  import { handleFocus, emptyConvert, calculateMeanvalue } from "@/views/reportForms/utils";
  import { getLqnRhlqclwjlbBsInfo } from "@/api/report_lqn/lqn";
  import BsInstrumentView from "@/views/dept/bsInstrument/BsInstrumentView.vue";
  import BsJiancyjView from "@/views/sycs/bsJiancyj/BsJiancyjView.vue";
  import BsJudgeBaseView from "@/views/sycs/bsJudgeBase/BsJudgeBaseView.vue";
  import BaQjDetailView from "@/views/sycs/baQjDetail/BaQjDetailView.vue";
  import TableLineLogChart from "@/views/reportForms/components/TableLineLogChart.vue";

  export default {
    name: "rhlqclwjlb",
    components: {
      BsInstrumentView,
      BsJiancyjView,
      BsJudgeBaseView,
      BaQjDetailView,
      TableLineLogChart
    },
    props: {
      excelId: {
        type: [String, Number],
        default: () => ""
      },
      syType: {
        type: [String, Number],
        default: () => ""
      },
      page: {
        type: Number,
        default: () => 0
      },
      isPdf: {
        type: Boolean,
        default: () => false
      },
      printEmpty: {
        type: Boolean,
        default: () => false
      }
    },
    data () {
      return {
        form: {
          detailList: [],
          baobbhList: []
        },
        show: false,
        pjzBg: null
      };
    },
    watch: {
      isPdf (newVal, oldVal) {
        this.form = { ...emptyConvert(this.form, newVal) };
      }
    },
    created () {
      this.init();
    },

    mounted () {
    },
    beforeDestroy () {
    },
    methods: {
      // 根据报表id获取当前报表信息
      init () {
        this.show = false;
        getLqnRhlqclwjlbBsInfo(this.excelId || this.$defaultExcelId).then((response) => {
          this.form = response.data;
          this.setInitialValue();
          if (!this.form.detailList || this.form.detailList.length <= 0) {
            this.getDetailList();
          }
          this.show = true;
          if (!this.form.fujsm) {
            this.form.fujsm = "附加声明：";
          }
        });
      },
      // 设置初始值
      setInitialValue () {
        if (this.form) {
          this.form.baobmc = this.form.baobmc || "乳化沥青蒸发残留物含量试验检测记录表";
          this.form.baobbh = this.form.baobbh || "JGLQ10015";
          this.$set(this.form, "baobbhList", []);
          this.form.baobbhList = ["JGLQ10015"];
        }
      },
      getDetailList () {
        this.$set(this.form, "detailList", []);
        for (let i = 0; i<8; i++) {
          const d1 = {
            detailId: undefined,
            excelId: this.excelId,
            yangpbh: undefined,
            hejzl: undefined,
            ruyhjzl: undefined,
            canlwhjzl: undefined,
            canlwhl: undefined,
            canlwhlPjz: undefined,
          };
          this.form.detailList.push(d1);
        }
      },
      // 显示检测依据列表
      showBsJiancyjView () {
        this.$refs.bsJiancyjViewRef.init(this.form.jiancyjIds);
      },
      // 检测依据选择
      selectJiancyj (info) {
        this.form.jiancyj = info.label;
        this.form.jiancyjIds = info.ids;
        Bus.$emit("setHntqdhtfBgJiancyj", { jiancyj: this.form.jiancyj, jiancyjIds: this.form.jiancyjIds });
      },
      // 显示判定依据列表
      showBsJudgeBaseView () {
        this.$refs.bsJudgeBaseViewRef.init(this.form.pandyjIds);
      },
      // 判断依据选择
      selectJudge (info) {
        if (!this.form.pandyj) {
          this.form.pandyj = info.label;
          return;
        }
        if (info && info.label) {
          this.form.pandyj += "、" + info.label;
        }
      },
      // 显示仪器列表
      showBsInstrumentView () {
        this.$refs.bsInstrumentViewRef.init(this.form.shebIds);
      },
      // 仪器选择
      selectInstrument (info) {
        this.form.zhuyyqsbmcjbh = info.label;
        this.form.shebIds = info.ids;
        Bus.$emit("setHntqdhtfBgZhuyyqsbmcjbh", { zhuyyqsbmcjbh: this.form.zhuyyqsbmcjbh, shebIds: this.form.shebIds });
      },
      // 传值试验条件
      setHntqdhtfBgShiytj () {
        const info = {
          shiytjwd: this.form.shiytjwd,
          shiytjsd: this.form.shiytjsd
        };
        Bus.$emit("setHntqdhtfBgShiytj", info);
      },
      submitForm () {
        return this.form;
      },
      handleFocus (event) {
        handleFocus(event, this.page, this.form[event]);
      },
      // 残留物含量计算
      calcClw(index) {
        // 判断奇偶
        const jo = index % 2 == 0 ? true : false;
        const item = this.form.detailList[index];
        if (item.hejzl && item.ruyhjzl && item.canlwhjzl) {
          const a = decimal.subtract(item.canlwhjzl, item.hejzl);
          const b = decimal.multiply(a, 100);
          const c = decimal.subtract(item.ruyhjzl, item.hejzl);
          if (c != 0) {
            const d = decimal.divide(b, c);
            this.form.detailList[index].canlwhl = d;
          } else {
            this.form.detailList[index].canlwhl = null;
          }
        } else {
          this.form.detailList[index].canlwhl = null;
        }
        this.calcPjz(jo, index);
      },
      calcPjz(jo, index) {
        if (jo) {
          if (this.form.detailList[index].canlwhl && this.form.detailList[index+1].canlwhl) {
            const a = decimal.add(this.form.detailList[index].canlwhl, this.form.detailList[index+1].canlwhl);
            const b = decimal.divide(a, 2);
            this.form.detailList[index].canlwhlPjz = b;
          } else {
            this.form.detailList[index].canlwhlPjz = null;
          }
        } else {
          if (this.form.detailList[index-1].canlwhl && this.form.detailList[index].canlwhl) {
            const a = decimal.add(this.form.detailList[index-1].canlwhl, this.form.detailList[index].canlwhl);
            const b = decimal.divide(a, 2);
            this.form.detailList[index-1].canlwhlPjz = b;
          } else {
            this.form.detailList[index-1].canlwhlPjz = null;
          }
        }
        this.calcPjzBg();
      },
      // 报告均值传参
      calcPjzBg() {
        let t = 0;
        let v = 0;
        if (this.form.detailList[0].canlwhlPjz) {
          t = decimal.add(t, this.form.detailList[0].canlwhlPjz);
          v = v + 1;
        }
        if (this.form.detailList[2].canlwhlPjz) {
          t = decimal.add(t, this.form.detailList[2].canlwhlPjz);
          v = v + 1;
        }
        if (this.form.detailList[4].canlwhlPjz) {
          t = decimal.add(t, this.form.detailList[4].canlwhlPjz);
          v = v + 1;
        }
        if (this.form.detailList[6].canlwhlPjz) {
          t = decimal.add(t, this.form.detailList[6].canlwhlPjz);
          v = v + 1;
        }
        if (v != 0) {
          const b = decimal.divide(t, v);
          this.pjzBg = b;
        } else {
          this.pjzBg = null;
        }
        Bus.$emit("setLqnBgJiancjg", [
          { key: 203, value: this.pjzBg }, // 残留物含量
        ]);
      },

    }
  };
</script>

<style scoped></style>
